<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 导入分页插件文件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <!-- 分页导航容器 -->
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>
</body>

</html>

<!-- 文章类别下拉框模板结构 -->
<script type="text/html" id="tpl-category">
    <option value="">所有分类</option>
    {{each data}}
    <option value="{{$value.id}}">{{$value.name}}</option>
    {{/each}}
</script>

<!-- 文章列表模板结构 -->
<script type="text/html" id="tpl-list">
    {{each data.data}}
    <tr>
        <td>{{$value.title}}</td>
        <td>{{$value.author}}</td>
        <td>{{$value.category}}</td>
        <td class="text-center">{{$value.date}}</td>
        <td class="text-center">{{$value.state}}</td>
        <td class="text-center">
            <a href="article_edit.html?articleid={{$value.id}}" data-id="{{$value.id}}" class="btn btn-default btn-xs">编辑</a>
            <a href="javascript:void(0);" data-id="{{$value.id}}" class="btn btn-danger btn-xs delete">删除</a>
        </td>
    </tr>
    {{/each}}
</script>

<script src="./libs/https.js"></script>
<script>
    $(function(){
        // 1. 发起ajax请求,获得所有的文章类别
        $.ajax(
            {
                url:BigNew.category_list,
                success: function (backData) {
                    // 2. 根据模板引擎生成标签字符串
                    let htmlStr = template('tpl-category', backData);
                    $('#selCategory').html(htmlStr);
                }
            }
        )

        // 声明一个全局变量,来保存当前被选中的页码
        let selPage = 1;

        // 3. 获得文章列表数据
        // 参数page: 当前选中的页码
        function loadData(page) {
            selPage = page;
            $.ajax(
                {
                    url: BigNew.article_query,
                    data: {
                        // 直接获得下拉框被选中的值
                        type: $('#selCategory').val(),
                        state: $('#selStatus').val(),
                        // 请求哪一页数据
                        page: page,
                        // 每页显示几条数据
                        perpage: 5
                    },
                    success: function (backData){
                        if(backData.code == 200) {
                            // 判断是否有数据
                            if(backData.data.totalCount > 0) {
                                // 4. 根据返回的数据,结合模板引擎渲染结构
                                let htmlStr = template('tpl-list',backData);
                                $('tbody').html(htmlStr);

                                // 5. 当数据加载完毕之后,根据总页数生成分页导航
                                // 设置分页导航
                                // 分页插件的一个很傻逼的缺点: 所有的属性设置只有第一次才能生效
                                // 如果总页数发生改变,作者建议先销毁原来的插件,再重新设置
                                $('#pagination').twbsPagination('destroy');
                                $('#pagination').twbsPagination({
                                    // 设置总页数
                                    totalPages: backData.data.totalPage,
                                    // 当前可见页数
                                    visiblePages: 7,
                                    // 当前选中的页码
                                    startPage: page,
                                    // 控制初始化点击(关闭效果)
                                    initiateStartPageClick: false,
                                    first:'首页',
                                    last:'尾页',
                                    next:'下一页',
                                    prev:'上一页',
                                    // 分页插件的点击事件
                                    // event: 事件对象
                                    // page: 当前被点击的页码
                                    onPageClick: function (event, page) {
                                        // 6. 根据点击的页数page发起ajax请求,获得数据
                                        loadData(page);
                                    }
                                });
                            } else {
                                // 代表此时并没有数据返回
                                $('tbody').empty();
                                $('#pagination').text('当前类别没有任何数据.....');
                            }
                        }
                    }
                }
            )
        }
        // 首次加载第一页的数据
        loadData(1);


        // 7. 给筛选按钮设置点击事件
        $('#btnSearch').on('click',function (e) {
            e.preventDefault();
            // 阻止默认效果
            // 8. 根据文章类别以及文章状态发起ajax请求
            loadData(1);
        })

        // 9. 给所有删除按钮设置点击事件
        $('tbody').on('click','.delete',function () {
            let delId = $(this).attr('data-id');
            // 10. 发起ajax请求,删除指定的文章
            $.ajax(
                {
                    type: 'post',
                    url: BigNew.article_delete,
                    data: {
                        id: delId
                    },
                    success: function (backData) {
                        // 11. 删除成功之后,应该重新获得数据
                        if(backData.code == 204) {
                            if ($('tbody>tr').length > 1 || selPage == 1) {
                                // 如果不是最后一条被删除,则还在当前页加载数据
                                // 在哪一页删除,就应该加载哪一页的数据
                                loadData(selPage);
                            }else {
                                // 当前删除的是最后一条,则应该加载上一页的数据
                                loadData(selPage - 1);
                            }
                        }
                    }
                }
            )
        })

        // 10. 给文章发布按钮设置点击事件
        $('#release_btn').on('click',function() {
            // 让主页(父页面)的二级菜单被选中
            parent.$('.level02 li').eq(1).click();
        })

    })
</script>